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BRANCH INSTRUCTIONS WITH DECOUPLED CONDITION AND ADDRESS 



BACKGROUND OF THE INVENTION 
1. Field of the Invention 
5 This invention relates to the field of computer systems, and in 

particular to processor instruction sets. 



2. Description of Related Art 

Computer systems utilize "branch" instructions to control 

10 program flow. In a conventional computer system comprising a 
processor and a memory that contains program instructions, the 
processor executes each program instruction in the memory in 
sequential order, one instruction at a time. A branch instruction is 
used to execute program instructions that are located at a specified 

15 location in memory, thereby altering the default execution of 

instructions at sequential memory locations. A conditional branch is 
used to either continue to process the instructions in sequential 
order, or to branch to a specified location in memory, depending 
upon a given condition. The condition is tested, and if the 

20 condition is true, the computer processor continues execution at a 
specified address, otherwise, the processor continues execution at 
the next sequential location. 

Other f low-of-control instructions are also available in most 
computer systems, such as a subroutine or function "call" and a 

25 corresponding "return". (For ease of reference, a function is 

considered hereinafter as a subset of a subroutine.) As in a branch 
instruction, a subroutine "call" is used to execute program 
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instructions that are located at a specified location. As contrast 
to the branch instruction, a call instruction also causes the 
processor to store the address of the next sequential instruction 
after the location of the call instruction (the "return address") ♦ 
In this manner, a corresponding subroutine "return" instruction will 
cause the processor to continue execution at the stored return 
address. Conditional call and return instructions operate similar to 
the above referenced conditional branch instruction. 

The conventional branch and call instructions include two 
items: an operation-code (op-code) that identifies the instruction 
as a branch or call instruction, and the address at which the next 
instruction is located. A conventional return instruction, on the 
other hand, only includes the operation code. The conventional 
conditional branch, call, and return instructions are similar to the 
unconditional branch, call, and return instructions, except that 
alternative op-codes are used to identify the alternative 
condition (s) that are used to determine whether to branch to a 
destination-address or to continue with the next sequential 
instruction after the conditional instruction. 

Typically, an application program contains many branches and 
subroutine calls, and often branches and subroutine calls to the 
same destination address are used repeatedly. For example, a 
"select-case" programming construct allows different segments of 
program instructions to be executed, depending upon a value of a 
given parameter, such as a "filing-status" parameter (single, 
married filing jointly, married filing individually, etc.) in an 
income tax preparation application program. Within each different 
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segment of the program corresponding to the value of the given 
parameter, the same subroutines may be called, albeit with different 
determined arguments, or with a different combination or order of 
subroutines, or with a different set of conditions, and so on, 
5 Because each conventional branch or call command requires the 
inclusion of the destination-address, a significant amount of 
address redundancy exists in a typical program. Subroutine return 
instructions do not incur this address redundancy penalty, but are 
limited in use to causing a return from a subroutine call. 

10 The evaluation of conditional instructions in a typical program 

application can also be problematic. A typical processor includes a 
set of "flags", and a conditional instruction effects an operation, 
such as a branch, return, or call, in dependence upon the state of 
one or more of these flags. Different instructions affect the state 

15 of different flags. For example, some instructions affect all flags, 
some instructions affect no flags, other instructions affect select 
flags, and so on. A common programming "bug" occurs when a change is 
made to a program that uses an instruction that affects flags, 
without an exhaustive assessment of the effects that a potential 

20 change in the state of each flag will cause. Because the added 

instruction may result in the same flag state as the intended flag* 
setting instruction, this error may not be immediately detected, and 
the effects of the error may not be associated with this change. 

In a typical high-performance computer system, instructions are 

25 pre-f etched from memory so that they are available to the processor 
for execution as soon as the processor is ready to execute the next 
instruction. In a typical pre-fetch operation, the system pre- 
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fetches a block of sequential instructions from the system memory 
into a block of memory that is local to the processor, and therefore 
immediately available to the processor. When a branch occurs, the 
previously pre-fetched instructions that sequentially follow the 
5 branch instruction in memory are replaced by the instructions from 
the memory at the specified destination address. This replacement 
incurs a performance cost while the processor waits for the next 
instruction from the system memory. Most systems include a "look 
ahead" capability, wherein the pre-fetch operator looks ahead in the 

10 program code being executed to identify the next branch of control. 
When an unconditional branch is detected, the pre-fetch operator 
pre-fetches the information from the specified destination-address 
so that it can provide it to the processor immediately after the 
branch command is processed. The use of pre-f etching for conditional 

15 branch instructions is substantially more complex, because it is 
unknown whether the next instruction executed after the branch 
instruction will be the instruction at the destination address or 
the instruction immediately following the branch instruction. If 
sufficient local memory is available, segments of instructions from 

20 both areas of the system memory are pre-fetched. Alternatively, or 
in addition to this multiple pre-fetch technique, predictive 
techniques are often used to pre-fetch the instructions that are 
likely to be executed. Such predictive techniques are subject to a 
high degree of variability because in most cases, the state of the 

25 condition is virtually unpredictable. 



BRIEF SUMMARY OF THE INVENTION 
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It is an object of this invention to enhance the efficiency of 
a computer system. It is a further object of this invention to 
enhance the reliability and maintainability of a program operated on 
a computer system. It is a further object of this invention to 
5 improve the predictive aspects of a pre-fetch system. It is a 
further object of this invention to ease the task of program 
development. 

These objects, and others, are achieved by providing an 
architecture that supports the decoupling of parameters typically 

10 associated with branch instructions. Branch and call instructions 
are provided that do not contain an explicit destination address; 
and, branch, call, and return instructions are provided that do not 
contain an explicit test condition. In accordance with this 
invention, the processing system provides a "default" value to any 

15 control element in the processor that is not expressly controlled by 
a particular instruction. In the case of a branch or call 
instruction, the default destination-address provided to effect the 
branch or call is the destination-address provided by a prior 
instruction. Subsequent or alternative branch or call instructions 

20 branch to this same address until the default address is set to a 
different address. In like manner, in most cases, the default 
condition that is used to determine the result of a conditional 
test, such as a conditional branch, call, or return instruction, is 
the last condition specified in a prior instruction. To further 

25 support the above objects of this invention, and others, condition- 
testing can also be effected prior to the execution of conditional 
instructions. By decoupling the specification of the condition 
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and/ or the destination address from the instructions that cause a 
branch, call, or return, these instructions can be configured to 
effect other operations, such as modifying registers or memory 
elements in preparation for processing by the routine to which the 
5 program branches or returns. Also, by providing an explicit means 
for setting a subsequent default destination address and by 
providing an explicit means for preevaluating a condition flag, 
program development and maintenance costs can be expected to 
decrease, and the variability associated with predicting the outcome 
10 and destination-address of conditional branches can also be expected 
to decrease. 



BRIEF DESCRIPTION OF THE DRAWINGS 
The invention is explained in further detail, and by way of 
15 example, with reference to the accompanying drawings wherein: 

FIG. 1 illustrates an example processing system in accordance with 
this invention. 

FIG. 2 illustrates an example instruction set format in accordance 
with this invention. 
20 Throughout the drawings, the same reference numerals indicate 

similar or corresponding features or functions. 



DETAILED DESCRIPTION OF THE INVENTION 
FIG. 1 illustrates an example block diagram of a processing 
25 system 100 that provides for a decoupling of conditions and 

destination addresses from branch instructions, in accordance with 
this invention. One of ordinary skill in the art will recognize, in 
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view of this disclosure, that alternative example embodiments can be 
defined to effect similar results. In the example of FIG. 1, an 
instruction 110 is provided from a program memory 160; this 
instruction is decoded by a mapper /default device 140 to provide a 
5 microcode instruction 155 that controls the operation of processing 
circuitry 150. In response to the microcode instruction 155 , the 
processing circuitry 150 effects desired operations on data 
contained in registers 170 or memory 180. The processing circuitry 
150 also determines each next instruction address 151 at each 

10 processing cycle, from which each next instruction 110 is obtained 
from the program memory 160. 

As in a conventional processor, the microcode instruction 155 
that comprises control bits 155b that control each switch and state 
device within the processing circuitry 150. That is, for example, 

15 the processing circuitry 150 typically comprises a state machine and 
the microcode instruction 155 provide the input stimuli to this 
state machine that controls the transition to the next state as well 
as controlling the production of an output from this state machine. 
The microcode instruction 155, for example, contains a control bit 

20 that will determine whether data will be received from one of the 
registers 170, whether a location in memory 180 will be written to 
or read from, and so on. The control bits 155b also determine the 
operation, such as addition, subtraction, shift, and so on, that 
will be performed on the data received from the registers 170 or 

25 memory 180, and whether other control bits 155b will be affected by 
the operation. The microcode instruction 155 also includes a 
"constant" field k 155a. This constant field k 155a is typically 
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used in a variety of applications. The field k 155a may contain, for 
example, the aforementioned destination-address of a branch or call 
instruction, in either absolute form, or relative form. The field k 
155a may also contain a constant that is used in the aforementioned 
5 mathematical operations on the data contained in the registers 170 
or memory 180. 

In this example embodiment, as in most processor embodiments, 
there are fewer bits in the instruction 110 than control elements 
155a and 155b in the microcode instruction 155. Conventionally, each 

10 instruction is formatted to contain sufficient information for 

effecting that instruction. In particular, in conventional processor 
designs, a branch or call instruction contains an explicit 
designation of a destination address, either as an absolute address, 
or as an offset, or relative address, relative to the current 

15 instruction address 151. 

In accordance with the principles of this invention, the 
mapper/ default device 140 provides default values for control 
elements 155a and 155b that are not explicitly controlled by the 
current instruction 110. In this manner, prior instructions can be 

20 configured to specify such items as the destination-address of a 
branch or call instruction, the condition to be tested for a 
conditional branch, call, or return instruction, and so on. In 
effect, because the mapper/default device 140 allows a destination- 
address from a prior instruction to be saved for use in a subsequent 

25 instruction, the mapper/ default device 140 comprises a "default- 
destination-address" register that is accessible by any instruction 
that does not contain an explicit destination-address. In like 
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manner, the mapper /default device 140 in accordance with this 
invention provides a "condition" register that is accessible by any 
instruction that does not contain an explicit condition 
specification . 

5 FIG. 2 illustrates an example of a set of eight different 

instruction formats 201-208 for use in an example embodiment in 
accordance with this invention. The format field 210 of each 
instruction identifies its corresponding format 201-208. Format 201 
illustrates an example format that is well suited for data 

10 processing operations. Copending U.S. Patent Application "Simple 

Algorithmic Cryptography Engine", U.S. serial number , 

filed for George Fleming, Farrell Ostler, and Antoine 

Dagher, Attorney Docket (Disclosure 701049) , incorporated 

by reference herein, discloses a processing system that allows for 

15 multiple operations within a single instruction cycle. Consistent 
with the referenced patent application, select registers 170 are 
used to address the memory 180, as illustrated in FIG. 1. The 
instruction format 201 allows for an addressed memory element to be 
written to or read from, via the Mem 212 field; it also allows for a 

20 variety of arithmetic and logical (shift) operations to be performed 
on the retrieved memory element, via the DataOp 213 field; and, it 
allows addressed registers to be updated, such as load, increment, 
decrement, or shift, via the A-update 214 and B-update 215 fields. 
That is, in accordance with the referenced patent application, data 

25 can be retrieved from memory, operated upon, the result stored in a 
register, and another register incremented, all in the same 
instruction 110. 
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Instruction format 202 corresponds substantially to a 
conventional branch or call instruction, hereinafter termed a "jump" 
operation. The field "Kll" 223 of the format 202 allows for a 
constant, in this example, a constant of 11 bits, that is used to 

5 specify a destination address. The field "jump" 224 defines the type 
of jump: call, branch, return, relative, absolute, and so on, and 
the field "cond" 225 defines the condition, if any, that controls a 
conditional jump. If the condition is true, the next instruction 
address (151 in FIG. 1) is the address contained in the Kll field 

10 223, zero extended; otherwise the next instruction address 151 is 
the next sequential address after the address of the current 
instruction 110. In accordance with the reference patent 
application, the instruction format 2 02 also allows a memory 
operation (store, retrieve) during the same instruction cycle, via 

15 the "mem" 222 field, thereby facilitating, for example, the 

retrieval of a data item in preparation for the commencement of the 
routine at the destination-address, or a storage of a data item at 
the end of a cycle controlled by a conditional branch. 

In accordance with this invention, the instruction set includes 

20 a format 203 that allows for the inclusion of a jump 234 field 
without an explicit specification of a destination-address. By 
allowing a jump without an explicit specification of a destination- 
address, the instruction can contain other operations, such as the 
DataOp 233 field that controls the operation on data items, as 

25 discussed above with regard to the DataOp 213 field. By providing 
the DataOp 233 field in the same instruction that includes a jump 
234 field, a new data value can be computed as a preparation for the 
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procedure being jumped to via the field 234, or, for example, a 
function value can be computed and stored in the memory 180 (FIG. 1) 
upon a return jump from a subroutine. 

The format 204 provides additional capabilities in parallel 
5 with a jump operation. As illustrated, the format 204 includes a B- 
update 245 field, similar to the B-update 215 field, in lieu of a 
condition field. This allows a select register to be updated in 
parallel with a jump operation. In addition to preparing a data item 
for the subsequent jump, or storing a computed data item upon return 

10 from a subroutine, this update field 245 can be used, for example, 
to increment a loop index during the same instruction that branches 
back to the start of the loop. Additional uses of the availability 
of parallel operations with a jump command, as provided by the 
decoupling of the destination-address and/or the condition tests 

15 from the jump command, will be evident to one of ordinary skill in 
the art in view of this disclosure. 

Formats 2 05-2 08 are further variations of this decoupling. In 
formats 205 and 208, a condition field 255, 285 is provided, without 
a corresponding jump field. In this manner, the a default-condition 

20 can be specified that controls all subsequent jump operations, until 
another instruction 225, 235, 255, 285 resets the default-condition. 
In formats 206, 207, and 208, a constant field 265, 275, 283 is 
provided that can be used to specify a default destination-address 
for subsequent jump operations. Depending upon the particular 

25 convention utilized, these constant fields can be utilized to 
provide either an absolute address, or a relative address. In 
accordance with this invention, the default destination-address that 

s:\pi\spl5pia0.pir.doc PHA 23891 



is specified by each of the fields 223, 265, 275, 283 control the 
destination of all subsequent jump operations, in conjunction with 
other fields, until the default destination-address is changed by 
another instruction 202, 206, 207, 208. Format 207 provides a jump 
5 274 field and the constant field 275 that sets the default 

destination-address, but the condition that controls the jump is not 
specified. In each of the formats 203-208, the decoupling of the 
jump, condition, and address fields allows one or more other fields, 
such as the above described Data-Op 213 field, the A-update 214, and 

10 B-update 215 field, to be included in the instruction, to optimize 
the number of instructions required to effect a task, and/ or to 
optimize the speed of execution of the task, by allowing for a 
variety of parallel operations in each instruction. 

The illustrated mapper /default device 140 of FIG. 1 provides an 

15 example embodiment of an instruction processing technique to support 
the above decoupled operations. As illustrated in FIG. 1, each bit 
of the instruction 110 is mapped to a corresponding control element 
in the microcode instruction 155. The mapper /default device 140 
comprises a plurality of selectors 141-149 that route each bit of 

20 the control field 110b to a corresponding control bit 155b, 

depending upon the given format 110a of the instruction 110. The 
mapper /default device 140 routes the different fields from the same 
bit position of an instruction 110 to different control elements 
155a, 155b of the microcode instruction 155, depending upon the 

25 format 110a of the instruction 110. The mapper/default device 140 
also appropriately controls the other control elements of the 
microcode instruction 155, those that are not controlled via the 
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mapping from the instruction 110, by providing default control 
values for each control element 155a, 155b of the microcode 
instruction 155. That is, for example, the example instruction 
formats 201, 203 do not include a constant field for setting the 
5 value of k 155a in the microcode instruction 155. The default 

interpretation for the absence of a specified constant field in an 
instruction 110 in a preferred embodiment is a null operation. That 
is, in the absence of a specified constant value, the value k 155a 
remains the same. Alternatively, as illustrated in format 206 of 

10 FIG. 2, when a short, 6-bit value of k is provided in a field K6 
265, the default value for the k 155a control element is a sign- 
extended value of the K6 265 field. A subsequent relative jump 
operation, via, for example, the jump 234 field of format 203, can 
use this signed value k 155a to compute a destination-address by 

15 adding this value k 155a to the current instruction address 151. 
In a preferred embodiment, the output of the 
multiplexer/selector 141-149 associated with each control element 
155 is dependent upon the content of the format field 210, and the 
inputs are dependent upon the available default options. The choice 

20 of a default value or condition for each control element 155a, 155b 
of the microcode instruction 155 can be any value or condition, but 
in a preferred embodiment, the default values and conditions are 
chosen to be those that would be consistent with an assumed value by 
one of ordinary skill in the art. That is, for example, the zero-ing 

25 of higher order bits when a data constant Kll 223 is provided, and 
the sign-extension of higher order bits when a shorter constant K6 
265 is provided, would be assumed to be proper defaults by one of 
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ordinary skill in the art. In like manner, the default condition of 
the set of control bits corresponding to the absence of a jump 234 
field would be assumed to correspond to an advancement of the 
program counter by one instruction. That is, when an instruction 
5 having a format 201 is received, which does not contain a jump 234 
field, the default interpretation module 140 sets the appropriate 
control elements in the macroinstruction 155 corresponding to the 
absent field 234 such that the corresponding selectors within the 
set 141-149 are set to select the appropriate inputs to effect an 

10 increment of the next-instruction-address 151, thereby providing a 
consistent, predictable, and logical effect in the absence of an 
explicit instruction field. 

In accordance with another aspect of this invention, the flags 
211 field includes control bits that further facilitate the use of 

15 decoupled jump instructions. As is common in the art of processing 
systems, the processing circuitry includes a set of "status flags" 
that represent the result of particular operations. These status 
flags include, for example, a "zero" flag that is asserted when the 
result of a mathematical operation is zero, a "carry" flag that is 

20 asserted when the result of a mathematical operation produces an 
overflow, and so on. One of the flag 211 bits is an "update flags" 
control bit that effects a preservation of the determined flag 
values until a subsequent instruction is executed that also has this 
control bit set. In this manner, when a condition, such as "Branch 

25 if Carry" is executed, its result will be determined by the flag 
that was updated in a prior instruction. 
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Another control bit in the flags 211 field saves a result of a 
condition-test into a "saved condition" register, for subsequent use 
in a conditional jump instruction. The example formats 202, 203, and 
205, for example, includes a condition field, 225, 235, and 255, 
5 respectively. The condition field 225, 235, 255 contains a 

specification of the particular condition to test, such as whether 
the zero flag is set, the carry flag is set, and so on. If the "save 
condition" control bit is set, the result of the tested condition is 
saved into the "saved condition" register, for subsequent use in a 

10 conditional jump instruction. In a preferred embodiment, whenever 
the "save condition" control bit is set, the default control bits 
155b that control the selection of the condition to utilize for a 
conditional jump instruction are set to select this "saved 
condition" register. 

15 By providing one or more flags that maintain their state 

through other changes of the processor's state, a number of 
advantages can be realized. As mentioned above, the likelihood of an 
inadvertent modification of a condition flag during a program update 
is reduced, because in a preferred embodiment, an explicit setting 

20 of the "update flags" or "save condition" control bits in an 

instruction is required to modify the persistent flag(s) . Also, the 
predetermination of the condition for a conditional branch allows 
for a highly effective pre-fetch operation, because it is highly 
likely, and often determinable, that the persistent condition flag 

25 will not change before the conditional branch is executed. The 

presetting of a persistent flag also allows the data item(s) upon 
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which the condition of the flag is set to change as required without 
affecting the subsequent conditional instructions. 

The foregoing merely illustrates the principles of the 
invention. It will thus be appreciated that those skilled in the 
5 art will be able to devise various arrangements which, although not 
explicitly described or shown herein, embody the principles of the 
invention and are thus within its spirit and scope. For example, the 
principles of this invention can also be effected by providing a 
separate "destination-address register" that is configured to hold 

10 the default destination address, independent of the particular 

processor architecture utilized. That is, although a microcode and 
state machine architecture is presented herein as a suitable 
embodiment to utilize decoupled control conditions, the principles 
presented herein can be embodied in any processor architecture by 

15 including specific devices for storing the decoupled information. 
These and other system configuration and optimization features will 
be evident to one of ordinary skill in the art in view of this 
disclosure, and are included within the scope of the following 
claims. 

20 
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CLAIMS 

I claim: 

1. A processor that is configured to execute program instructions 
that are stored in a memory , comprising 

5 a default-register that is configured to contain a default- 

destination-address , and 
wherein 

the program instructions include: 

a first instruction that is configured to cause the 
10 processor to load a specified address into the default-register to 
form the default-destination-address, and 

a second instruction that is configured to cause the 
processor to subsequently execute program instructions that are 
located in the memory at the default-destination-address contained 
15 in the default-register. 

2. The processor of claim 1, wherein 

the second instruction includes a condition test and is further 
configured to cause the processor to execute program instructions 
20 that are located at the default-destination-address in dependence 
upon a result of the condition test. 

3. The processor of claim 1, wherein 

the default-register is further configured to contain a 
25 default-condition-test, and 
wherein 

the second instruction is further configured to cause the 
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processor to execute program instructions that are located at the 
clef ault-destination-address in dependence upon a result of the 
default-condition-test contained in the default-register. 

5 4. The processor of claim 1, wherein 

the second instruction is further configured to cause 
processor to execute program instructions that are located 
default-destination-address in dependence upon a result of 
condition- test . 

10 

5. The processor of claim 1, wherein 

the default-register is further configured to contain a 
default-condition-test , and 

wherein 

15 the program instructions further include: 

a third instruction that is configured to cause the 
processor to execute program instructions that are located at 
another specified address in dependence upon a result of the 
default-condition-test contained in the default-register. 

20 
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6. A processor that is configured to execute program instructions 
that are stored in a memory, comprising 

a default-register that is configured to contain a default- 
condition-test , and 
5 wherein 

the program instructions include: 

a first instruction that is configured to cause the 
processor to load a specified condition into the default-register to 
form the default-condition-test, and 
10 a second instruction that is configured to cause the 

processor to subsequently execute program instructions that are 
located in the memory at a destination-address, based on a result of 
the default-condition-test. 
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7. A method of controlling a sequence of program instructions 
comprising: 

executing a first instruction that specifies a destination- 
address, 

5 executing a second instruction that causes the destination- 

address to become a next instruction address, and 

executing a third instruction that is located at the next 
instruction address, 

10 8. The method of claim 7, further including 

executing a fourth instruction, before executing the second 
instruction, that specifies a condition-test, and 
wherein 

causing the destination-address to become the next instruction 
15 address is dependent upon a result of the condition-test when the 
second instruction is executed. 

9. The method of claim 7, further including 

saving a result of a condition-test, before executing the 
20 second instruction, and 
wherein 

causing the destination-address to become the next instruction 
address when executing the second instruction is dependent upon the 
result of the condition-test. 

25 
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Branch Instructions with Decoupled Condition and Address 

ABSTRACT OF THE DISCLOSURE 
A processor architecture is provided that supports the 

5 decoupling of parameters typically associated with branch/ jump 

instructions. Jump instructions are provided that do not contain an 
explicit destination address and other jump instructions are 
provided that do not contain an explicit test condition. In 
accordance with this invention, the processing system provides a 

10 "default" value to any control element in the processor that is not 
expressly controlled by a particular instruction. In the case of a 
branch or call instruction, the default destination-address provided 
to effect the branch or call is the destination-address provided by 
a prior instruction. Subsequent or alternative branch or call 

15 instructions branch to this same address until the default address 
is set to a different address. In like manner, in most cases, the 
default condition that is used to determine the result of a 
conditional test, such as a conditional branch, call, or return 
instruction, is the last condition specified in a prior instruction. 

20 To further support the above objects of this invention, and others, 
condition-testing can also be effected prior to the execution of 
conditional instructions. 
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As a below named inventor, I hereby declare that: 

My residence, post office address and citizenship are as stated below next to my name. 

I believe I am the original, first and sole inventor (if only one name is listed below) or an original, first and joint inventor (if plural names are listed 
below) of the subject matter which is claimed and for which a patent is sought on the invention entitled "BRANCH INSTRUCTIONS WITH 

DECOUPLED CONDITION AND ADDRESS' 

the specification of which (check one) 
_X_ is attached hereto. 

was filed on as Application Serial No, and was amended on 

(if applicable). 

I hereby state that I have reviewed and understand the contents of the above-identified specification, including the claims, as amended by the 
amendments) referred to above. 

I acknowledge the duty to disclose information which is material to the patentability of this application in accordance with Title 37, Code of Federal 
Regulation^ 1.56(a). 

I hereby claim foreign priority benefits under Title 35, United States Code, § 1 19 of any foreign application^) for patent or inventor's certificate listed 
below and have also identified below any foreign application for patent or inventor's certificate having a filing date before that of the application on which 
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COUNTRY 


APPLICATION 
NUMBER 


DATE OF FILING 
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PRIORITY CLAIMED 
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I hereby claim the benefit under Title 35, United States Code, §120 of any United States application (s) listed below and, insofar as the subject matter of 
each of the claims of this application is not disclosed in the prior United States application in the manner provided by the first paragraph of Title 35 United 
States Code, §1 12, 1 acknowledge the duty to disclose material information as defined in Title 37, Code of Federal Regulations, § 1.56(a) which occurred 
between the filing date of the prior application and the national or PCT international filing date of this application: 



PRIOR UNITED STATES APPLICATION(S) 



APPLICATION SERIAL NUMBER 


FILING DATE 


STATUS (PATENTED, PENDING, ABANDONED) 















I hereby declare that all statements made herein of my own knowledge are true and that all statements made on information and belief are believed to be 
true; and further that these statements were made with the knowledge that willful false statements and the like so made are punishable by fine or 
imprisonment, or both, under Section 100 1 of Title 18 of the United States Code and that such willful false statements may jeopardize the validity of the 
application or any patent issued thereon. 



POWER OF ATTORNEY: As a named inventor, I hereby appoint the following attorneys) and/or agent(s) to prosecute this application and transact all 
business in the Patent and Trademark Office connected therewith, (list name and registration number) 
Algy Tamoshunas, Reg. No. 27,677 
Jack E. Haken, Reg. No. 26,902 



SEND CORRESPONDENCE TO: 
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Corporate Patent Counsel; 


(name and telephone No.) Tony Piotrowski 


U.S. Philips Corporation; 580 White Plains Road; Tarrytown, NY 10591 
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Inventor 


Last Name OSTLER 
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Middle Name L. 


Residence & 
Citizenship 


City ALBUQUERQUE 


State or Foreign Country 
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Country of Citizenship 
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Post Office 
Address 


Street 9223 MERIWETHER AVE, N.W. 
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State or Country 
NEW MEXICO 


Zip Code 
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Dated: / 
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Middle Name FARID 


Residence & 
Citizenship 
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State or Foreign Country 
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Country of Citizenship 
U.S. 
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Address 


Street 6709 PLATT PLACE NW 


CITY ALBUQUERQUE 


State or Country 
NEW MEXICO 


Zip Code 
87114 



Dated: 




Inventor's Signature: 
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Last Name 
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Citizenship 


City 


State or foreign Country 
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Post Office 
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IN THE UNITED STATES PATENT AND TRADEMARK OFFICE 
In re Application of Atty. Docket 

FARRELL L. OSTLER ET AL PHA 23,891 

Serial No. Group Art Unit: 

Filed: CONCURRENTLY Examiner: 

Title: BRANCH INSTRUCTIONS WITH DECOUPLED CONDITION AND ADDRESS 

Honorable Commissioner of Patents and Trademarks 
Washington, D.C. 20231 

APPOINTMENT OF ASSOCIATES 

Sir: 

The undersigned Attorney of Record hereby revokes all 
prior appointments (if any) of Associate Attorney (s) or Agent (s) in 
the above-captioned case and appoints: 
Tony Piotrowski (Registration No* 42,080) 

(Registration No. ) and 

(Registration No. ) 
c/o U.S. PHILIPS CORPORATION, Intellectual Property Department, 580 
White Plains Road, Tarrytown, New York 10591, his Associate 
Attorney (s) /Agent (s) with all the usual powers to prosecute the 
above-identified application and any division or continuation 
thereof, to make alterations and amendments therein, and to 
transact all business in the Patent and Trademark Office connected 
therewith . 

ALL CORRESPONDENCE CONCERNING THIS APPLICATION AND THE 
LETTERS PATENT WHEN GRANTED SHOULD BE ADDRESSED TO THE UNDERSIGNED 
ATTORNEY OF RECORD. 

Respectfully, 




Jfck E. Haken, Reg. 26,902 
Axyorney of Record 



Dated at Tarrytown, New York 
this December 15, 1999 
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